草庐IT

指向类的 C++ 指针

全部标签

pointers - 如何定义一个函数,该函数接收一个指针作为参数并返回一个指向该参数的子节点之一的指针?

现在我正在学习Go,这是我第一次接触指针。但这有点棘手,我开始怀疑我这样做是对还是错。标题是我最好的猜测,试图用外语解释我想做的事情,所以如果不清楚,我可以尝试用不同的方式解释。这是代码的简化示例:https://play.golang.org/p/eultYp7Cq12funchasCity(elementstring,state*State)(bool,*City){for_,city:=range(*state).Cities{if(city.Name==element){returntrue,&city}}returnfalse,nil}如您所见,输出为:true&{Campi

pointers - 如何通过 Go 中的 map 指针更改/访问 map 实例的值?

假设我们有代码:varCache_map*map[string]intCache_map=new(map[string]int)那我们要在Cache_map中加入key:type&value1,怎么办? 最佳答案 在这种情况下不需要new、make或映射指针。骨架/示例:packagemainimport"fmt"varCacheMap=map[string]int{}funcmain(){CacheMap["type"]=1fmt.Printf("%#v\n",CacheMap)}Playground输出:map[string]i

go - 为什么分配给指针会导致 panic

我有以下代码:typeboxstruct{valint}varp*box这很好用:p=&box{val:2}但这会导致错误:*p=box{val:2}错误:panic:runtimeerror:invalidmemoryaddressornilpointerdereference[signalSIGSEGV:segmentationviolationcode=0x1addr=0x0pc=0x5e59d9]为什么第二种形式的赋值会导致panic? 最佳答案 因为p不指向任何内容(nil)。您必须先分配一些内存并使p指向它,然后才能引用

pointers - 取消引用结构指针是否复制结构?

我有thiscode:typecountHolderstruct{countint}funcmain(){a:=&countHolder{1}b:=*aa.count=2println(b.count)}我预计输出为2,但输出为1。我的理解是:a:=&countHolder{1}//a是指向数据从地址x开始的结构的指针b:=*a//b现在等于地址xa.count=2//存储在地址x的结构体的计数值变为2我哪里错了?b:=*a是在创建结构的副本吗? 最佳答案 来自finespecification:Foranoperandxoftyp

pointers - 检查 Go 中字符串指针的长度

如何找到来自结构的字符串指针的长度。目前正在写单元测试,想看看一个字符串指针是否小于250个字符。如果r是my并且myString是字符串指针。此代码无效:iflen(r.myString)>256{returnErrStringTooLong} 最佳答案 您应该解释为什么您的代码不正确,以及您收到的错误消息。如果它是一个指向字符串的指针,你应该用asterix*len(*r.myString) 关于pointers-检查Go中字符串指针的长度,我们在StackOverflow上找到一个

go - 为什么用指针分配接口(interface)然后分配地址在 Golang 中显示不同的行为

我刚接触golang。我从go之旅开始。这是goplaygroundlink代码如下:packagemainimport"fmt"typeIinterface{M()}typeTstruct{Sstring}func(t*T)M(){fmt.Println(t.S)}funcmain(){variIvart*Ti=ti.M()}panicpanic:runtimeerror:invalidmemoryaddressornilpointerdereference[signalSIGSEGV:segmentationviolationcode=0xffffffffaddr=0x0pc=0x

pointers - 如何检测golang中的结构指针是否为nil?

如下代码所示:n:=localplugin.NewPluginNet(),n的类型为localnet.Net,这是一个由结构指针*localnet.DomainSocket实现的接口(interface)。函数funcNewPluginNet()localnet.Net返回一个指向n的nil指针。varnlocalnet.Netn=localplugin.NewPluginNet()fmt.Println("---->",n)ifn==nil{fmt.Println("nisnil")}else{fmt.Println("nisnotnil:",n)}fmt.Println(refle

go - 使用指针序列化结构

具有如下结构层次结构:typeDomainStorestruct{Domains[]*DomainUsers[]*User}typeDomainstruct{NamestringRecords[]*RecordOwner*User}typeUserstruct{NamestringEmailstringDomains[]*Domain}typeRecordstruct{NamestringHoststring}单个DomainStore具有域和用户列表,指针位于域和用户之间。我正在寻找一种对文件进行序列化/反序列化的方法。我一直在尝试使用gob,但指针没有(按设计)正确序列化(扁平化)

go - 来自接口(interface)值的底层指针类型

如何从接口(interface)获取底层指针类型?packagemainimport("fmt")typeCarinterface{Drive()string}typeMyCarstruct{namestring}func(MyCar)Drive()string{return"rumrum"}funcmain(){varcarCarmycar:=&MyCar{name:"mycar"}car=mycarmycarptr,err:=car.(*MyCar)mycarvalue,err2:=car.(MyCar)fmt.Printf("asptrfailed:%t,asvaluefaile

go - 当指向结构的指针被替换时,GC 的行为如何

我正在学习Go,并且正在阅读图书馆中的示例。我发现一些示例正在使用:typeMyTypestruct{Codestring//...}funcmain(){myType:=&MyType{...}//...myType=&MyType{...}}基本上他们是在重用变量。我知道&MyType{..}返回一个指针,稍后我可以替换该指针。之前指向的内存会发生什么。GC会回收该内存还是我会浪费该内存。也许这是一个愚蠢的问题,我什么都不担心,但我正在尝试学习Go来构建性能API:) 最佳答案 内存将被垃圾收集器回收。如果你想替换结构你可以这样